package com.mytx.pojo;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class ContactExample {
    protected String orderByClause;

    protected boolean distinct;

    protected List<Criteria> oredCriteria;

    public ContactExample() {
        oredCriteria = new ArrayList<Criteria>();
    }

    public void setOrderByClause(String orderByClause) {
        this.orderByClause = orderByClause;
    }

    public String getOrderByClause() {
        return orderByClause;
    }

    public void setDistinct(boolean distinct) {
        this.distinct = distinct;
    }

    public boolean isDistinct() {
        return distinct;
    }

    public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

    public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

    public Criteria or() {
        Criteria criteria = createCriteriaInternal();
        oredCriteria.add(criteria);
        return criteria;
    }

    public Criteria createCriteria() {
        Criteria criteria = createCriteriaInternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }

    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

    public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
    }

    protected abstract static class GeneratedCriteria {
        protected List<Criterion> criteria;

        protected GeneratedCriteria() {
            super();
            criteria = new ArrayList<Criterion>();
        }

        public boolean isValid() {
            return criteria.size() > 0;
        }

        public List<Criterion> getAllCriteria() {
            return criteria;
        }

        public List<Criterion> getCriteria() {
            return criteria;
        }

        protected void addCriterion(String condition) {
            if (condition == null) {
                throw new RuntimeException("Value for condition cannot be null");
            }
            criteria.add(new Criterion(condition));
        }

        protected void addCriterion(String condition, Object value, String property) {
            if (value == null) {
                throw new RuntimeException("Value for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value));
        }

        protected void addCriterion(String condition, Object value1, Object value2, String property) {
            if (value1 == null || value2 == null) {
                throw new RuntimeException("Between values for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value1, value2));
        }

        public Criteria andCIdIsNull() {
            addCriterion("c_id is null");
            return (Criteria) this;
        }

        public Criteria andCIdIsNotNull() {
            addCriterion("c_id is not null");
            return (Criteria) this;
        }

        public Criteria andCIdEqualTo(String value) {
            addCriterion("c_id =", value, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdNotEqualTo(String value) {
            addCriterion("c_id <>", value, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdGreaterThan(String value) {
            addCriterion("c_id >", value, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdGreaterThanOrEqualTo(String value) {
            addCriterion("c_id >=", value, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdLessThan(String value) {
            addCriterion("c_id <", value, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdLessThanOrEqualTo(String value) {
            addCriterion("c_id <=", value, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdLike(String value) {
            addCriterion("c_id like", value, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdNotLike(String value) {
            addCriterion("c_id not like", value, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdIn(List<String> values) {
            addCriterion("c_id in", values, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdNotIn(List<String> values) {
            addCriterion("c_id not in", values, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdBetween(String value1, String value2) {
            addCriterion("c_id between", value1, value2, "cId");
            return (Criteria) this;
        }

        public Criteria andCIdNotBetween(String value1, String value2) {
            addCriterion("c_id not between", value1, value2, "cId");
            return (Criteria) this;
        }

        public Criteria andMIdIsNull() {
            addCriterion("m_id is null");
            return (Criteria) this;
        }

        public Criteria andMIdIsNotNull() {
            addCriterion("m_id is not null");
            return (Criteria) this;
        }

        public Criteria andMIdEqualTo(String value) {
            addCriterion("m_id =", value, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdNotEqualTo(String value) {
            addCriterion("m_id <>", value, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdGreaterThan(String value) {
            addCriterion("m_id >", value, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdGreaterThanOrEqualTo(String value) {
            addCriterion("m_id >=", value, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdLessThan(String value) {
            addCriterion("m_id <", value, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdLessThanOrEqualTo(String value) {
            addCriterion("m_id <=", value, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdLike(String value) {
            addCriterion("m_id like", value, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdNotLike(String value) {
            addCriterion("m_id not like", value, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdIn(List<String> values) {
            addCriterion("m_id in", values, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdNotIn(List<String> values) {
            addCriterion("m_id not in", values, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdBetween(String value1, String value2) {
            addCriterion("m_id between", value1, value2, "mId");
            return (Criteria) this;
        }

        public Criteria andMIdNotBetween(String value1, String value2) {
            addCriterion("m_id not between", value1, value2, "mId");
            return (Criteria) this;
        }

        public Criteria andTIdIsNull() {
            addCriterion("t_id is null");
            return (Criteria) this;
        }

        public Criteria andTIdIsNotNull() {
            addCriterion("t_id is not null");
            return (Criteria) this;
        }

        public Criteria andTIdEqualTo(String value) {
            addCriterion("t_id =", value, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdNotEqualTo(String value) {
            addCriterion("t_id <>", value, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdGreaterThan(String value) {
            addCriterion("t_id >", value, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdGreaterThanOrEqualTo(String value) {
            addCriterion("t_id >=", value, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdLessThan(String value) {
            addCriterion("t_id <", value, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdLessThanOrEqualTo(String value) {
            addCriterion("t_id <=", value, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdLike(String value) {
            addCriterion("t_id like", value, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdNotLike(String value) {
            addCriterion("t_id not like", value, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdIn(List<String> values) {
            addCriterion("t_id in", values, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdNotIn(List<String> values) {
            addCriterion("t_id not in", values, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdBetween(String value1, String value2) {
            addCriterion("t_id between", value1, value2, "tId");
            return (Criteria) this;
        }

        public Criteria andTIdNotBetween(String value1, String value2) {
            addCriterion("t_id not between", value1, value2, "tId");
            return (Criteria) this;
        }

        public Criteria andStatusIsNull() {
            addCriterion("status is null");
            return (Criteria) this;
        }

        public Criteria andStatusIsNotNull() {
            addCriterion("status is not null");
            return (Criteria) this;
        }

        public Criteria andStatusEqualTo(String value) {
            addCriterion("status =", value, "status");
            return (Criteria) this;
        }

        public Criteria andStatusNotEqualTo(String value) {
            addCriterion("status <>", value, "status");
            return (Criteria) this;
        }

        public Criteria andStatusGreaterThan(String value) {
            addCriterion("status >", value, "status");
            return (Criteria) this;
        }

        public Criteria andStatusGreaterThanOrEqualTo(String value) {
            addCriterion("status >=", value, "status");
            return (Criteria) this;
        }

        public Criteria andStatusLessThan(String value) {
            addCriterion("status <", value, "status");
            return (Criteria) this;
        }

        public Criteria andStatusLessThanOrEqualTo(String value) {
            addCriterion("status <=", value, "status");
            return (Criteria) this;
        }

        public Criteria andStatusLike(String value) {
            addCriterion("status like", value, "status");
            return (Criteria) this;
        }

        public Criteria andStatusNotLike(String value) {
            addCriterion("status not like", value, "status");
            return (Criteria) this;
        }

        public Criteria andStatusIn(List<String> values) {
            addCriterion("status in", values, "status");
            return (Criteria) this;
        }

        public Criteria andStatusNotIn(List<String> values) {
            addCriterion("status not in", values, "status");
            return (Criteria) this;
        }

        public Criteria andStatusBetween(String value1, String value2) {
            addCriterion("status between", value1, value2, "status");
            return (Criteria) this;
        }

        public Criteria andStatusNotBetween(String value1, String value2) {
            addCriterion("status not between", value1, value2, "status");
            return (Criteria) this;
        }

        public Criteria andGroupNameIsNull() {
            addCriterion("group_name is null");
            return (Criteria) this;
        }

        public Criteria andGroupNameIsNotNull() {
            addCriterion("group_name is not null");
            return (Criteria) this;
        }

        public Criteria andGroupNameEqualTo(String value) {
            addCriterion("group_name =", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameNotEqualTo(String value) {
            addCriterion("group_name <>", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameGreaterThan(String value) {
            addCriterion("group_name >", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameGreaterThanOrEqualTo(String value) {
            addCriterion("group_name >=", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameLessThan(String value) {
            addCriterion("group_name <", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameLessThanOrEqualTo(String value) {
            addCriterion("group_name <=", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameLike(String value) {
            addCriterion("group_name like", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameNotLike(String value) {
            addCriterion("group_name not like", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameIn(List<String> values) {
            addCriterion("group_name in", values, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameNotIn(List<String> values) {
            addCriterion("group_name not in", values, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameBetween(String value1, String value2) {
            addCriterion("group_name between", value1, value2, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameNotBetween(String value1, String value2) {
            addCriterion("group_name not between", value1, value2, "groupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameIsNull() {
            addCriterion("t_group_name is null");
            return (Criteria) this;
        }

        public Criteria andTGroupNameIsNotNull() {
            addCriterion("t_group_name is not null");
            return (Criteria) this;
        }

        public Criteria andTGroupNameEqualTo(String value) {
            addCriterion("t_group_name =", value, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameNotEqualTo(String value) {
            addCriterion("t_group_name <>", value, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameGreaterThan(String value) {
            addCriterion("t_group_name >", value, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameGreaterThanOrEqualTo(String value) {
            addCriterion("t_group_name >=", value, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameLessThan(String value) {
            addCriterion("t_group_name <", value, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameLessThanOrEqualTo(String value) {
            addCriterion("t_group_name <=", value, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameLike(String value) {
            addCriterion("t_group_name like", value, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameNotLike(String value) {
            addCriterion("t_group_name not like", value, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameIn(List<String> values) {
            addCriterion("t_group_name in", values, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameNotIn(List<String> values) {
            addCriterion("t_group_name not in", values, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameBetween(String value1, String value2) {
            addCriterion("t_group_name between", value1, value2, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andTGroupNameNotBetween(String value1, String value2) {
            addCriterion("t_group_name not between", value1, value2, "tGroupName");
            return (Criteria) this;
        }

        public Criteria andLocationIsNull() {
            addCriterion("location is null");
            return (Criteria) this;
        }

        public Criteria andLocationIsNotNull() {
            addCriterion("location is not null");
            return (Criteria) this;
        }

        public Criteria andLocationEqualTo(String value) {
            addCriterion("location =", value, "location");
            return (Criteria) this;
        }

        public Criteria andLocationNotEqualTo(String value) {
            addCriterion("location <>", value, "location");
            return (Criteria) this;
        }

        public Criteria andLocationGreaterThan(String value) {
            addCriterion("location >", value, "location");
            return (Criteria) this;
        }

        public Criteria andLocationGreaterThanOrEqualTo(String value) {
            addCriterion("location >=", value, "location");
            return (Criteria) this;
        }

        public Criteria andLocationLessThan(String value) {
            addCriterion("location <", value, "location");
            return (Criteria) this;
        }

        public Criteria andLocationLessThanOrEqualTo(String value) {
            addCriterion("location <=", value, "location");
            return (Criteria) this;
        }

        public Criteria andLocationLike(String value) {
            addCriterion("location like", value, "location");
            return (Criteria) this;
        }

        public Criteria andLocationNotLike(String value) {
            addCriterion("location not like", value, "location");
            return (Criteria) this;
        }

        public Criteria andLocationIn(List<String> values) {
            addCriterion("location in", values, "location");
            return (Criteria) this;
        }

        public Criteria andLocationNotIn(List<String> values) {
            addCriterion("location not in", values, "location");
            return (Criteria) this;
        }

        public Criteria andLocationBetween(String value1, String value2) {
            addCriterion("location between", value1, value2, "location");
            return (Criteria) this;
        }

        public Criteria andLocationNotBetween(String value1, String value2) {
            addCriterion("location not between", value1, value2, "location");
            return (Criteria) this;
        }

        public Criteria andTLocationIsNull() {
            addCriterion("t_location is null");
            return (Criteria) this;
        }

        public Criteria andTLocationIsNotNull() {
            addCriterion("t_location is not null");
            return (Criteria) this;
        }

        public Criteria andTLocationEqualTo(String value) {
            addCriterion("t_location =", value, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationNotEqualTo(String value) {
            addCriterion("t_location <>", value, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationGreaterThan(String value) {
            addCriterion("t_location >", value, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationGreaterThanOrEqualTo(String value) {
            addCriterion("t_location >=", value, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationLessThan(String value) {
            addCriterion("t_location <", value, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationLessThanOrEqualTo(String value) {
            addCriterion("t_location <=", value, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationLike(String value) {
            addCriterion("t_location like", value, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationNotLike(String value) {
            addCriterion("t_location not like", value, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationIn(List<String> values) {
            addCriterion("t_location in", values, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationNotIn(List<String> values) {
            addCriterion("t_location not in", values, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationBetween(String value1, String value2) {
            addCriterion("t_location between", value1, value2, "tLocation");
            return (Criteria) this;
        }

        public Criteria andTLocationNotBetween(String value1, String value2) {
            addCriterion("t_location not between", value1, value2, "tLocation");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteIsNull() {
            addCriterion("relation_infinite is null");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteIsNotNull() {
            addCriterion("relation_infinite is not null");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteEqualTo(String value) {
            addCriterion("relation_infinite =", value, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteNotEqualTo(String value) {
            addCriterion("relation_infinite <>", value, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteGreaterThan(String value) {
            addCriterion("relation_infinite >", value, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteGreaterThanOrEqualTo(String value) {
            addCriterion("relation_infinite >=", value, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteLessThan(String value) {
            addCriterion("relation_infinite <", value, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteLessThanOrEqualTo(String value) {
            addCriterion("relation_infinite <=", value, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteLike(String value) {
            addCriterion("relation_infinite like", value, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteNotLike(String value) {
            addCriterion("relation_infinite not like", value, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteIn(List<String> values) {
            addCriterion("relation_infinite in", values, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteNotIn(List<String> values) {
            addCriterion("relation_infinite not in", values, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteBetween(String value1, String value2) {
            addCriterion("relation_infinite between", value1, value2, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andRelationInfiniteNotBetween(String value1, String value2) {
            addCriterion("relation_infinite not between", value1, value2, "relationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteIsNull() {
            addCriterion("t_relation_infinite is null");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteIsNotNull() {
            addCriterion("t_relation_infinite is not null");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteEqualTo(String value) {
            addCriterion("t_relation_infinite =", value, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteNotEqualTo(String value) {
            addCriterion("t_relation_infinite <>", value, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteGreaterThan(String value) {
            addCriterion("t_relation_infinite >", value, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteGreaterThanOrEqualTo(String value) {
            addCriterion("t_relation_infinite >=", value, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteLessThan(String value) {
            addCriterion("t_relation_infinite <", value, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteLessThanOrEqualTo(String value) {
            addCriterion("t_relation_infinite <=", value, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteLike(String value) {
            addCriterion("t_relation_infinite like", value, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteNotLike(String value) {
            addCriterion("t_relation_infinite not like", value, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteIn(List<String> values) {
            addCriterion("t_relation_infinite in", values, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteNotIn(List<String> values) {
            addCriterion("t_relation_infinite not in", values, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteBetween(String value1, String value2) {
            addCriterion("t_relation_infinite between", value1, value2, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTRelationInfiniteNotBetween(String value1, String value2) {
            addCriterion("t_relation_infinite not between", value1, value2, "tRelationInfinite");
            return (Criteria) this;
        }

        public Criteria andTagIsNull() {
            addCriterion("tag is null");
            return (Criteria) this;
        }

        public Criteria andTagIsNotNull() {
            addCriterion("tag is not null");
            return (Criteria) this;
        }

        public Criteria andTagEqualTo(String value) {
            addCriterion("tag =", value, "tag");
            return (Criteria) this;
        }

        public Criteria andTagNotEqualTo(String value) {
            addCriterion("tag <>", value, "tag");
            return (Criteria) this;
        }

        public Criteria andTagGreaterThan(String value) {
            addCriterion("tag >", value, "tag");
            return (Criteria) this;
        }

        public Criteria andTagGreaterThanOrEqualTo(String value) {
            addCriterion("tag >=", value, "tag");
            return (Criteria) this;
        }

        public Criteria andTagLessThan(String value) {
            addCriterion("tag <", value, "tag");
            return (Criteria) this;
        }

        public Criteria andTagLessThanOrEqualTo(String value) {
            addCriterion("tag <=", value, "tag");
            return (Criteria) this;
        }

        public Criteria andTagLike(String value) {
            addCriterion("tag like", value, "tag");
            return (Criteria) this;
        }

        public Criteria andTagNotLike(String value) {
            addCriterion("tag not like", value, "tag");
            return (Criteria) this;
        }

        public Criteria andTagIn(List<String> values) {
            addCriterion("tag in", values, "tag");
            return (Criteria) this;
        }

        public Criteria andTagNotIn(List<String> values) {
            addCriterion("tag not in", values, "tag");
            return (Criteria) this;
        }

        public Criteria andTagBetween(String value1, String value2) {
            addCriterion("tag between", value1, value2, "tag");
            return (Criteria) this;
        }

        public Criteria andTagNotBetween(String value1, String value2) {
            addCriterion("tag not between", value1, value2, "tag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagIsNull() {
            addCriterion("infinite_tag is null");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagIsNotNull() {
            addCriterion("infinite_tag is not null");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagEqualTo(String value) {
            addCriterion("infinite_tag =", value, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagNotEqualTo(String value) {
            addCriterion("infinite_tag <>", value, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagGreaterThan(String value) {
            addCriterion("infinite_tag >", value, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagGreaterThanOrEqualTo(String value) {
            addCriterion("infinite_tag >=", value, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagLessThan(String value) {
            addCriterion("infinite_tag <", value, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagLessThanOrEqualTo(String value) {
            addCriterion("infinite_tag <=", value, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagLike(String value) {
            addCriterion("infinite_tag like", value, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagNotLike(String value) {
            addCriterion("infinite_tag not like", value, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagIn(List<String> values) {
            addCriterion("infinite_tag in", values, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagNotIn(List<String> values) {
            addCriterion("infinite_tag not in", values, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagBetween(String value1, String value2) {
            addCriterion("infinite_tag between", value1, value2, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteTagNotBetween(String value1, String value2) {
            addCriterion("infinite_tag not between", value1, value2, "infiniteTag");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyIsNull() {
            addCriterion("infinite_key is null");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyIsNotNull() {
            addCriterion("infinite_key is not null");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyEqualTo(String value) {
            addCriterion("infinite_key =", value, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyNotEqualTo(String value) {
            addCriterion("infinite_key <>", value, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyGreaterThan(String value) {
            addCriterion("infinite_key >", value, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyGreaterThanOrEqualTo(String value) {
            addCriterion("infinite_key >=", value, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyLessThan(String value) {
            addCriterion("infinite_key <", value, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyLessThanOrEqualTo(String value) {
            addCriterion("infinite_key <=", value, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyLike(String value) {
            addCriterion("infinite_key like", value, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyNotLike(String value) {
            addCriterion("infinite_key not like", value, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyIn(List<String> values) {
            addCriterion("infinite_key in", values, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyNotIn(List<String> values) {
            addCriterion("infinite_key not in", values, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyBetween(String value1, String value2) {
            addCriterion("infinite_key between", value1, value2, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteKeyNotBetween(String value1, String value2) {
            addCriterion("infinite_key not between", value1, value2, "infiniteKey");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatIsNull() {
            addCriterion("infinite_chat is null");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatIsNotNull() {
            addCriterion("infinite_chat is not null");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatEqualTo(String value) {
            addCriterion("infinite_chat =", value, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatNotEqualTo(String value) {
            addCriterion("infinite_chat <>", value, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatGreaterThan(String value) {
            addCriterion("infinite_chat >", value, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatGreaterThanOrEqualTo(String value) {
            addCriterion("infinite_chat >=", value, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatLessThan(String value) {
            addCriterion("infinite_chat <", value, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatLessThanOrEqualTo(String value) {
            addCriterion("infinite_chat <=", value, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatLike(String value) {
            addCriterion("infinite_chat like", value, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatNotLike(String value) {
            addCriterion("infinite_chat not like", value, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatIn(List<String> values) {
            addCriterion("infinite_chat in", values, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatNotIn(List<String> values) {
            addCriterion("infinite_chat not in", values, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatBetween(String value1, String value2) {
            addCriterion("infinite_chat between", value1, value2, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andInfiniteChatNotBetween(String value1, String value2) {
            addCriterion("infinite_chat not between", value1, value2, "infiniteChat");
            return (Criteria) this;
        }

        public Criteria andUpChatIsNull() {
            addCriterion("up_chat is null");
            return (Criteria) this;
        }

        public Criteria andUpChatIsNotNull() {
            addCriterion("up_chat is not null");
            return (Criteria) this;
        }

        public Criteria andUpChatEqualTo(String value) {
            addCriterion("up_chat =", value, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatNotEqualTo(String value) {
            addCriterion("up_chat <>", value, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatGreaterThan(String value) {
            addCriterion("up_chat >", value, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatGreaterThanOrEqualTo(String value) {
            addCriterion("up_chat >=", value, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatLessThan(String value) {
            addCriterion("up_chat <", value, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatLessThanOrEqualTo(String value) {
            addCriterion("up_chat <=", value, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatLike(String value) {
            addCriterion("up_chat like", value, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatNotLike(String value) {
            addCriterion("up_chat not like", value, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatIn(List<String> values) {
            addCriterion("up_chat in", values, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatNotIn(List<String> values) {
            addCriterion("up_chat not in", values, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatBetween(String value1, String value2) {
            addCriterion("up_chat between", value1, value2, "upChat");
            return (Criteria) this;
        }

        public Criteria andUpChatNotBetween(String value1, String value2) {
            addCriterion("up_chat not between", value1, value2, "upChat");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureIsNull() {
            addCriterion("adjust_structure is null");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureIsNotNull() {
            addCriterion("adjust_structure is not null");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureEqualTo(String value) {
            addCriterion("adjust_structure =", value, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureNotEqualTo(String value) {
            addCriterion("adjust_structure <>", value, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureGreaterThan(String value) {
            addCriterion("adjust_structure >", value, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureGreaterThanOrEqualTo(String value) {
            addCriterion("adjust_structure >=", value, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureLessThan(String value) {
            addCriterion("adjust_structure <", value, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureLessThanOrEqualTo(String value) {
            addCriterion("adjust_structure <=", value, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureLike(String value) {
            addCriterion("adjust_structure like", value, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureNotLike(String value) {
            addCriterion("adjust_structure not like", value, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureIn(List<String> values) {
            addCriterion("adjust_structure in", values, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureNotIn(List<String> values) {
            addCriterion("adjust_structure not in", values, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureBetween(String value1, String value2) {
            addCriterion("adjust_structure between", value1, value2, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andAdjustStructureNotBetween(String value1, String value2) {
            addCriterion("adjust_structure not between", value1, value2, "adjustStructure");
            return (Criteria) this;
        }

        public Criteria andInviteMessageIsNull() {
            addCriterion("invite_message is null");
            return (Criteria) this;
        }

        public Criteria andInviteMessageIsNotNull() {
            addCriterion("invite_message is not null");
            return (Criteria) this;
        }

        public Criteria andInviteMessageEqualTo(String value) {
            addCriterion("invite_message =", value, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageNotEqualTo(String value) {
            addCriterion("invite_message <>", value, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageGreaterThan(String value) {
            addCriterion("invite_message >", value, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageGreaterThanOrEqualTo(String value) {
            addCriterion("invite_message >=", value, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageLessThan(String value) {
            addCriterion("invite_message <", value, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageLessThanOrEqualTo(String value) {
            addCriterion("invite_message <=", value, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageLike(String value) {
            addCriterion("invite_message like", value, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageNotLike(String value) {
            addCriterion("invite_message not like", value, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageIn(List<String> values) {
            addCriterion("invite_message in", values, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageNotIn(List<String> values) {
            addCriterion("invite_message not in", values, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageBetween(String value1, String value2) {
            addCriterion("invite_message between", value1, value2, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andInviteMessageNotBetween(String value1, String value2) {
            addCriterion("invite_message not between", value1, value2, "inviteMessage");
            return (Criteria) this;
        }

        public Criteria andUpdatedIsNull() {
            addCriterion("updated is null");
            return (Criteria) this;
        }

        public Criteria andUpdatedIsNotNull() {
            addCriterion("updated is not null");
            return (Criteria) this;
        }

        public Criteria andUpdatedEqualTo(Date value) {
            addCriterion("updated =", value, "updated");
            return (Criteria) this;
        }

        public Criteria andUpdatedNotEqualTo(Date value) {
            addCriterion("updated <>", value, "updated");
            return (Criteria) this;
        }

        public Criteria andUpdatedGreaterThan(Date value) {
            addCriterion("updated >", value, "updated");
            return (Criteria) this;
        }

        public Criteria andUpdatedGreaterThanOrEqualTo(Date value) {
            addCriterion("updated >=", value, "updated");
            return (Criteria) this;
        }

        public Criteria andUpdatedLessThan(Date value) {
            addCriterion("updated <", value, "updated");
            return (Criteria) this;
        }

        public Criteria andUpdatedLessThanOrEqualTo(Date value) {
            addCriterion("updated <=", value, "updated");
            return (Criteria) this;
        }

        public Criteria andUpdatedIn(List<Date> values) {
            addCriterion("updated in", values, "updated");
            return (Criteria) this;
        }

        public Criteria andUpdatedNotIn(List<Date> values) {
            addCriterion("updated not in", values, "updated");
            return (Criteria) this;
        }

        public Criteria andUpdatedBetween(Date value1, Date value2) {
            addCriterion("updated between", value1, value2, "updated");
            return (Criteria) this;
        }

        public Criteria andUpdatedNotBetween(Date value1, Date value2) {
            addCriterion("updated not between", value1, value2, "updated");
            return (Criteria) this;
        }

        public Criteria andCreatedIsNull() {
            addCriterion("created is null");
            return (Criteria) this;
        }

        public Criteria andCreatedIsNotNull() {
            addCriterion("created is not null");
            return (Criteria) this;
        }

        public Criteria andCreatedEqualTo(Date value) {
            addCriterion("created =", value, "created");
            return (Criteria) this;
        }

        public Criteria andCreatedNotEqualTo(Date value) {
            addCriterion("created <>", value, "created");
            return (Criteria) this;
        }

        public Criteria andCreatedGreaterThan(Date value) {
            addCriterion("created >", value, "created");
            return (Criteria) this;
        }

        public Criteria andCreatedGreaterThanOrEqualTo(Date value) {
            addCriterion("created >=", value, "created");
            return (Criteria) this;
        }

        public Criteria andCreatedLessThan(Date value) {
            addCriterion("created <", value, "created");
            return (Criteria) this;
        }

        public Criteria andCreatedLessThanOrEqualTo(Date value) {
            addCriterion("created <=", value, "created");
            return (Criteria) this;
        }

        public Criteria andCreatedIn(List<Date> values) {
            addCriterion("created in", values, "created");
            return (Criteria) this;
        }

        public Criteria andCreatedNotIn(List<Date> values) {
            addCriterion("created not in", values, "created");
            return (Criteria) this;
        }

        public Criteria andCreatedBetween(Date value1, Date value2) {
            addCriterion("created between", value1, value2, "created");
            return (Criteria) this;
        }

        public Criteria andCreatedNotBetween(Date value1, Date value2) {
            addCriterion("created not between", value1, value2, "created");
            return (Criteria) this;
        }
    }

    public static class Criteria extends GeneratedCriteria {

        protected Criteria() {
            super();
        }
    }

    public static class Criterion {
        private String condition;

        private Object value;

        private Object secondValue;

        private boolean noValue;

        private boolean singleValue;

        private boolean betweenValue;

        private boolean listValue;

        private String typeHandler;

        public String getCondition() {
            return condition;
        }

        public Object getValue() {
            return value;
        }

        public Object getSecondValue() {
            return secondValue;
        }

        public boolean isNoValue() {
            return noValue;
        }

        public boolean isSingleValue() {
            return singleValue;
        }

        public boolean isBetweenValue() {
            return betweenValue;
        }

        public boolean isListValue() {
            return listValue;
        }

        public String getTypeHandler() {
            return typeHandler;
        }

        protected Criterion(String condition) {
            super();
            this.condition = condition;
            this.typeHandler = null;
            this.noValue = true;
        }

        protected Criterion(String condition, Object value, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.typeHandler = typeHandler;
            if (value instanceof List<?>) {
                this.listValue = true;
            } else {
                this.singleValue = true;
            }
        }

        protected Criterion(String condition, Object value) {
            this(condition, value, null);
        }

        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.secondValue = secondValue;
            this.typeHandler = typeHandler;
            this.betweenValue = true;
        }

        protected Criterion(String condition, Object value, Object secondValue) {
            this(condition, value, secondValue, null);
        }
    }
}